#### CGS 3763: Operating System Concepts Spring 2006

#### Chapter 2 – Hardware – Part 2

| Instructor : | Mark Llewellyn                                |
|--------------|-----------------------------------------------|
|              | markl@cs.ucf.edu                              |
|              | CSB 242, 823-2790                             |
|              | http://www.cs.ucf.edu/courses/cgs3763/spr2006 |

#### School of Electrical Engineering and Computer Science University of Central Florida



Page 1



### Interrupts

- Interrupt the normal sequencing of the processor
- Most I/O devices are slower than the processor

- Processor must pause to wait for device

CGS 3763: Operating System Concepts (Chapter 2) Page 2





### **Classes of Interrupts**

| to perform certain functions on a regular basis.                                       | to perform certain functions on a regular basis.I/OGenerated by an I/O controller, to signal normal completion of an operation | Program          | Generated by some condition that occurs as a result of an instruction<br>execution, such as arithmetic overflow, division by zero, attempt to execute<br>an illegal machine instruction, and reference outside a user's allowed<br>memory space. |
|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                        | or to signal a variety of error conditions.                                                                                    | Timer            |                                                                                                                                                                                                                                                  |
|                                                                                        | Hardware failure Generated by a failure, such as power failure or memory parity error.                                         | I/O              |                                                                                                                                                                                                                                                  |
| Hardware failure Generated by a failure, such as power failure or memory parity error. |                                                                                                                                | Hardware failure | Generated by a failure, such as power failure or memory parity error.                                                                                                                                                                            |
|                                                                                        |                                                                                                                                |                  |                                                                                                                                                                                                                                                  |

CGS 3763: Operating System Concepts (Chapter 2)

#### Program Flow of Control Without Interrupts



CGS 3763: Operating System Concepts (Chapter 2)



#### Program Flow of Control With Interrupts, Short I/O Wait



CGS 3763: Operating System Concepts (Chapter 2)

Page 5



#### Program Flow of Control With Interrupts; Long I/O Wait



CGS 3763: Operating System Concepts (Chapter 2)



### Interrupt Handler

- Program to service a particular I/O device
- Generally part of the operating system





### Interrupts

• Suspends the normal sequence of execution



#### Interrupt Cycle



# Interrupt Cycle

- Processor checks for interrupts
- If no interrupts fetch the next instruction for the current program
- If an interrupt is pending, suspend execution of the current program, and execute the interrupt-handler routine



© Mark Llewellyn

#### Timing Diagram Based on Short I/O Wait



#### Timing Diagram Based on Long I/O Wait







#### Changes in Memory and Registers for an Interrupt



CGS 3763: Operating System Concepts (Chapter 2)

Page 14



#### Changes in Memory and Registers for an Interrupt

© Mark Llewellyn



### **Multiple Interrupts**

• Disable interrupts while an interrupt is being processed



#### **Multiple Interrupts**

• Define priorities for interrupts



#### **Multiple Interrupts**



# Multiprogramming

- Processor has more than one program to execute
- The sequence the programs are executed depend on their relative priority and whether they are waiting for I/O
- After an interrupt handler completes, control may not return to the program that was executing at the time of the interrupt



# Memory Hierarchy

- Faster access time, greater cost per bit
- Greater capacity, smaller cost per bit
- Greater capacity, slower access speed



# **Disk Cache**

- A portion of main memory used as a buffer to temporarily to hold data for the disk
- Disk writes are clustered
- Some data written out may be referenced again. The data are retrieved rapidly from the software cache instead of slowly from disk

Page 21



© Mark Llewellyn

### **Cache Memory**

- Invisible to operating system
- Increase the speed of memory
- Processor speed is faster than memory speed
- Exploit the principle of locality





### Cache Memory

- Contains a copy of a portion of main memory
- Processor first checks cache
- If not found in cache, the block of memory containing the needed information is moved to the cache and delivered to the processor



#### Cache/Main Memory System



#### **Cache Read Operation**



# Cache Design

- Cache size
  - Small caches have a significant impact on performance
- Block size
  - The unit of data exchanged between cache and main memory
  - Larger block size more hits until probability of using newly fetched data becomes less than the probability of reusing data that have to be moved out of cache



© Mark Llewellyn

# Cache Design

- Mapping function
  - Determines which cache location the block will occupy

Page 28

- Replacement algorithm
  - Determines which block to replace
  - Least-Recently-Used (LRU) algorithm

© Mark Llewellyn

# Cache Design

- Write policy
  - When the memory write operation takes place
  - Can occur every time block is updated
  - Can occur only when block is replaced
    - Minimizes memory write operations
    - Leaves main memory in an obsolete state



### Programmed I/O

- I/O module performs the action, not the processor
- Sets appropriate bits in the I/O status register
- No interrupts occur
- Processor checks status until operation is complete

CGS 3763: Operating System Concepts (Chapter 2)



### Interrupt-Driven I/O

- Processor is interrupted when I/O module ready to exchange data
- Processor saves context of program executing and begins executing interrupt-handler
- No needless waiting
- Consumes a lot of processor time because every word read or written passes through the processor

CGS 3763: Operating System Concepts (Chapter 2)



### **Direct Memory Access**

- Transfers a block of data directly to or from memory
- An interrupt is sent when the transfer is complete
- Processor continues with other work

